:root {
	--winsome-navy: #0c183f;
	--winsome-teal: #0a6d80;
	--winsome-teal-soft: #2f8d9a;
	--winsome-cream: #faf8f3;
	--winsome-border: rgba(12, 24, 63, 0.18);
}

body.winsome-auth-template {
	margin: 0;
	background: var(--winsome-cream);
}

.winsome-auth-page {
	display: grid;
	grid-template-columns: minmax(460px, 51.25vw) minmax(430px, 1fr);
	min-height: 100vh;
	color: var(--winsome-navy);
	background: var(--winsome-cream);
}

.winsome-auth-visual {
	position: relative;
	min-height: 100vh;
	background-image: linear-gradient(180deg, rgba(3, 8, 26, 0.12), rgba(3, 8, 26, 0.42)), var(--winsome-auth-bg);
	background-position: center;
	background-size: cover;
	overflow: hidden;
}

.winsome-auth-visual::after {
	position: absolute;
	inset: 0;
	content: "";
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.2), transparent 54%), linear-gradient(0deg, rgba(2, 7, 21, 0.34), transparent 58%);
}

.winsome-auth-visual__content {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: min(560px, calc(100% - 96px));
	min-height: 100vh;
	margin: 0 auto;
	padding: 15vh 0 11vh;
	color: #fff8ea;
	text-align: center;
}

.winsome-auth-visual__content {
	display: none;
}

.winsome-auth-mark__crest {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 58px;
	height: 58px;
	margin-bottom: 22px;
	border: 1px solid rgba(255, 248, 234, 0.9);
	border-radius: 50%;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 26px;
}

.winsome-auth-mark__name,
.winsome-auth-mark__tagline,
.winsome-auth-visual__bottom p {
	display: block;
	font-family: Arial, Helvetica, sans-serif;
	text-transform: uppercase;
}

.winsome-auth-mark__name {
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(32px, 3.6vw, 54px);
	line-height: 1;
	letter-spacing: 0.34em;
	text-indent: 0.34em;
}

.winsome-auth-mark__tagline {
	margin-top: 18px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.3em;
}

.winsome-auth-visual__bottom {
	text-align: left;
}

.winsome-auth-visual__bottom h2 {
	margin: 0 0 24px;
	color: #fff8ea;
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(42px, 4vw, 62px);
	font-weight: 400;
	line-height: 1.18;
	letter-spacing: 0;
}

.winsome-auth-visual__bottom .winsome-auth-ornament {
	margin-left: 74px;
}

.winsome-auth-visual__bottom p {
	margin: 26px 0 0;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.16em;
}

.winsome-auth-panel {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	padding: 64px 7vw;
	background: linear-gradient(135deg, #fff 0%, #faf8f3 58%, #f4ede4 100%);
	overflow: hidden;
}

.winsome-auth-panel__pattern {
	position: absolute;
	top: -54px;
	right: -52px;
	width: 210px;
	height: 210px;
	border: 2px solid rgba(12, 24, 63, 0.06);
	border-radius: 50%;
	opacity: 0.7;
}

.winsome-auth-card {
	position: relative;
	z-index: 1;
	width: min(100%, 620px);
}

.winsome-auth-header {
	margin-bottom: 38px;
	text-align: center;
}

.winsome-auth-header h1 {
	margin: 0;
	color: var(--winsome-navy);
	font-family: Georgia, "Times New Roman", serif;
	font-size: clamp(42px, 4vw, 60px);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: 0;
}

.winsome-auth-header p {
	margin: 22px 0 0;
	color: #3f4654;
	font-size: 18px;
	line-height: 1.55;
}

.winsome-auth-ornament {
	position: relative;
	display: block;
	width: 164px;
	height: 18px;
	margin: 22px auto 0;
	background: radial-gradient(circle at center, var(--winsome-teal-soft) 0 4px, transparent 4px);
}

.winsome-auth-ornament::before,
.winsome-auth-ornament::after {
	position: absolute;
	top: 8px;
	width: 64px;
	height: 1px;
	content: "";
	background: var(--winsome-teal-soft);
}

.winsome-auth-ornament::before {
	left: 0;
}

.winsome-auth-ornament::after {
	right: 0;
}

.winsome-auth-message {
	margin: 0 0 22px;
	padding: 14px 16px;
	border: 1px solid var(--winsome-border);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.72);
	color: var(--winsome-navy);
	font-size: 14px;
	line-height: 1.5;
}

.winsome-auth-message--error {
	border-color: rgba(180, 35, 24, 0.25);
	background: #fff1f0;
	color: #9f1d16;
}

.winsome-auth-message--success {
	border-color: rgba(47, 141, 154, 0.25);
	background: #edf9f8;
	color: #075c65;
}

.winsome-auth-message--info {
	border-color: rgba(12, 24, 63, 0.16);
	background: #f7f5ef;
}

.winsome-auth-form {
	margin: 0;
}

.winsome-auth-field {
	display: block;
	margin: 0 0 24px;
}

.winsome-auth-field > span:first-child {
	display: block;
	margin-bottom: 10px;
	color: #0e183c;
	font-size: 15px;
	font-weight: 600;
	line-height: 1.3;
}

.winsome-auth-input {
	position: relative;
	display: block;
}

.winsome-auth-input::before {
	position: absolute;
	top: 50%;
	left: 22px;
	width: 20px;
	height: 20px;
	content: "";
	background: currentColor;
	transform: translateY(-50%);
	opacity: 0.62;
	pointer-events: none;
}

.winsome-auth-input--email::before {
	clip-path: polygon(5% 18%, 95% 18%, 95% 82%, 5% 82%, 5% 18%, 50% 55%, 95% 18%, 95% 30%, 50% 67%, 5% 30%);
}

.winsome-auth-input--password::before {
	clip-path: polygon(24% 42%, 24% 30%, 30% 18%, 42% 12%, 58% 12%, 70% 18%, 76% 30%, 76% 42%, 86% 42%, 86% 88%, 14% 88%, 14% 42%, 24% 42%, 34% 42%, 34% 31%, 39% 25%, 50% 22%, 61% 25%, 66% 31%, 66% 42%);
}

.winsome-auth-input--user::before {
	clip-path: circle(28% at 50% 30%);
}

.winsome-auth-input--phone::before {
	clip-path: polygon(28% 4%, 72% 4%, 84% 14%, 84% 86%, 72% 96%, 28% 96%, 16% 86%, 16% 14%);
}

.winsome-auth-input--otp::before {
	clip-path: polygon(10% 20%, 90% 20%, 90% 80%, 10% 80%);
}

.winsome-auth-input input {
	width: 100%;
	height: 60px;
	padding: 0 58px;
	color: var(--winsome-navy);
	background: rgba(255, 255, 255, 0.75);
	border: 1px solid var(--winsome-border);
	border-radius: 6px;
	box-shadow: none;
	font-size: 16px;
}

.winsome-auth-input input:focus {
	border-color: var(--winsome-teal);
	outline: 0;
	box-shadow: 0 0 0 3px rgba(10, 109, 128, 0.12);
}

.winsome-password-toggle {
	position: absolute;
	top: 50%;
	right: 17px;
	width: 32px;
	height: 32px;
	padding: 0;
	background: transparent;
	border: 0;
	transform: translateY(-50%);
	cursor: pointer;
}

.winsome-password-toggle::before {
	position: absolute;
	top: 10px;
	left: 6px;
	width: 20px;
	height: 12px;
	content: "";
	border: 1.8px solid #4b5563;
	border-radius: 50%;
}

.winsome-password-toggle::after {
	position: absolute;
	top: 14px;
	left: 14px;
	width: 5px;
	height: 5px;
	content: "";
	background: #4b5563;
	border-radius: 999px;
}

.winsome-auth-options {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin: 2px 0 34px;
	font-size: 15px;
}

.winsome-auth-options label {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	margin: 0;
	color: #1f2937;
}

.winsome-auth-options input[type="checkbox"] {
	width: 22px;
	height: 22px;
	margin: 0;
	border: 1px solid rgba(12, 24, 63, 0.35);
	border-radius: 4px;
}

.winsome-auth-options a,
.winsome-auth-terms a {
	color: var(--winsome-teal);
	text-decoration: none;
}

.winsome-auth-submit,
.winsome-auth-otp,
.winsome-auth-secondary {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 62px;
	border-radius: 6px;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
}

.winsome-auth-submit {
	color: #fff;
	background: var(--winsome-navy);
	border: 0;
}

.winsome-auth-submit:hover,
.winsome-auth-submit:focus {
	background: #111f4f;
}

.winsome-auth-submit:disabled,
.winsome-auth-otp:disabled {
	cursor: wait;
	opacity: 0.68;
}

.winsome-auth-switch {
	margin-top: 40px;
	text-align: center;
}

.winsome-auth-switch > span {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 22px;
	margin-bottom: 32px;
	color: #6b7280;
	font-size: 15px;
}

.winsome-auth-switch > span::before,
.winsome-auth-switch > span::after {
	height: 1px;
	content: "";
	background: rgba(12, 24, 63, 0.14);
}

.winsome-auth-secondary {
	color: var(--winsome-teal);
	background: transparent;
	border: 1px solid var(--winsome-teal);
}

.winsome-auth-secondary:hover,
.winsome-auth-secondary:focus {
	color: #fff;
	background: var(--winsome-teal);
}

.winsome-auth-terms,
.winsome-auth-microcopy {
	color: #6b7280;
	font-size: 15px;
	line-height: 1.7;
}

.winsome-auth-terms {
	margin: 32px 0 0;
	text-align: center;
}

.winsome-auth-microcopy {
	margin: -8px 0 18px;
}

.winsome-auth-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.winsome-auth-otp-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 190px;
	gap: 18px;
	align-items: end;
}

.winsome-auth-otp {
	margin-bottom: 24px;
	color: var(--winsome-teal);
	background: transparent;
	border: 1px solid var(--winsome-teal);
	letter-spacing: 0.12em;
}

.winsome-auth-otp:hover,
.winsome-auth-otp:focus {
	color: #fff;
	background: var(--winsome-teal);
}

@media (max-width: 980px) {
	.winsome-auth-page {
		grid-template-columns: 1fr;
	}

	.winsome-auth-visual {
		min-height: 360px;
	}

	.winsome-auth-visual__content {
		justify-content: flex-end;
		min-height: 360px;
		padding: 42px 0;
	}

	.winsome-auth-mark {
		display: none;
	}

	.winsome-auth-panel {
		min-height: auto;
		padding: 48px 22px;
	}
}

@media (max-width: 620px) {
	.winsome-auth-visual {
		min-height: 280px;
	}

	.winsome-auth-visual__content {
		width: min(100%, calc(100% - 40px));
		min-height: 280px;
	}

	.winsome-auth-visual__bottom h2 {
		font-size: 32px;
	}

	.winsome-auth-visual__bottom p {
		font-size: 12px;
	}

	.winsome-auth-header {
		margin-bottom: 30px;
	}

	.winsome-auth-header h1 {
		font-size: 38px;
	}

	.winsome-auth-header p {
		font-size: 16px;
	}

	.winsome-auth-grid,
	.winsome-auth-otp-row {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.winsome-auth-otp {
		margin-top: -6px;
	}

	.winsome-auth-options {
		align-items: flex-start;
		flex-direction: column;
	}
}
