/* stylelint-disable no-descending-specificity */

/* Foundation Learn — learner access (sign-in, activate, welcome, reset) */

body.fl-page-learner-access {
	background: var(--fl-ivory, #f7f3ec);
	margin: 0;
}

body.fl-page-learner-access:not(.fl-lms-domain) {
	min-height: 100vh;
}

.fl-learner-access-shell {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	background: var(--fl-ivory, #f7f3ec);
}

body.fl-page-learner-access:not(.fl-lms-domain) .fl-learner-access-shell {
	min-height: 100vh;
}

@media (width >= 960px) {
	.fl-learner-access-shell {
		flex-direction: row;
		align-items: stretch;
	}
}

.fl-learner-access-shell__hero {
	display: flex;
	flex: 1;
	align-items: center;
	justify-content: center;
	padding: clamp(2.5rem, 6vw, 4rem) clamp(1.5rem, 5vw, 3rem);
	background: var(--fl-charcoal, #171717);
	color: var(--fl-ivory, #f7f3ec);
	text-align: left;
}

@media (width >= 960px) {
	.fl-learner-access-shell__hero {
		max-width: 50%;
		min-height: 100vh;
	}
}

.fl-learner-access-shell__hero-inner {
	width: min(100%, 26rem);
	margin: 0 auto;
}

.fl-learner-access-shell__logo-link {
	display: inline-block;
	color: inherit;
	text-decoration: none;
	margin-bottom: 2rem;
}

.fl-learner-access-shell__logo {
	display: block;
	height: calc(2.75rem * var(--fl-brand-logo-scale, 1));
	width: auto;
	max-height: calc(3rem * var(--fl-brand-logo-scale, 1));
	max-width: calc(min(18rem, 80vw) * var(--fl-brand-logo-scale, 1));
	object-fit: contain;
}

.fl-learner-access-shell__kicker {
	margin: 0 0 0.75rem;
	font-family: var(--fl-font-sans);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--fl-gold, #b98a3d);
}

.fl-learner-access-shell__title {
	margin: 0 0 1rem;
	font-family: var(--fl-font-display);
	font-size: clamp(2rem, 4.5vw, 2.75rem);
	font-weight: 400;
	line-height: 1.12;
	letter-spacing: -0.02em;
	color: var(--fl-ivory, #f7f3ec);
}

.fl-learner-access-shell__subtitle {
	margin: 0;
	font-family: var(--fl-font-sans);
	font-size: 1.0625rem;
	line-height: 1.65;
	color: var(--fl-text-on-dark, rgb(247 243 236 / 88%));
	max-width: 28rem;
}

.fl-learner-access {
	display: flex;
	flex: 1;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	width: 100%;
	margin: 0;
	padding: clamp(2rem, 5vw, 3.5rem) clamp(1.25rem, 4vw, 2rem);
}

@media (width >= 960px) {
	.fl-learner-access {
		max-width: 50%;
		min-height: 100vh;
	}
}

.fl-learner-access__inner {
	box-sizing: border-box;
	width: min(100%, 26rem);
	padding: clamp(1.75rem, 4vw, 2.25rem);
	background: var(--fl-white, #fff);
	border: 1px solid var(--fl-border, rgb(23 23 23 / 10%));
	border-radius: var(--fl-radius-lg, 16px);
	box-shadow: var(--fl-shadow-md, 0 8px 24px rgb(23 23 23 / 8%));
}

.fl-learner-access__logo {
	display: block;
	height: 2.5rem;
	width: auto;
	max-height: 2.5rem;
	object-fit: contain;
	margin-bottom: 1.5rem;
}

.fl-learner-access__title {
	margin: 0 0 0.5rem;
	font-family: var(--fl-font-display);
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.2;
	color: var(--fl-charcoal, #171717);
}

.fl-learner-access__subtitle {
	margin: 0 0 1.5rem;
	font-family: var(--fl-font-sans);
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--fl-stone, #8a847c);
}

.fl-learner-access__error {
	color: #b42318;
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	border: 1px solid rgb(180 35 24 / 20%);
	border-radius: var(--fl-radius-sm, 6px);
	background: rgb(180 35 24 / 5%);
	font-size: 0.875rem;
	line-height: 1.5;
}

.fl-learner-access__notice {
	color: #027a48;
	margin: 0 0 1rem;
	padding: 0.75rem 1rem;
	border: 1px solid rgb(2 122 72 / 20%);
	border-radius: var(--fl-radius-sm, 6px);
	background: rgb(2 122 72 / 5%);
	font-size: 0.875rem;
	line-height: 1.5;
}

.fl-learner-access__form {
	display: flex;
	flex-direction: column;
	gap: 1.125rem;
}

.fl-learner-access__field {
	margin: 0;
}

.fl-learner-access__field label {
	display: block;
	margin-bottom: 0.45rem;
	font-family: var(--fl-font-sans);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--fl-charcoal, #171717);
}

.fl-learner-access__field input[type="text"],
.fl-learner-access__field input[type="password"],
.fl-learner-access__field input[type="email"] {
	width: 100%;
	box-sizing: border-box;
	padding: 0.8rem 0.95rem;
	border: 1px solid var(--fl-border-strong, rgb(23 23 23 / 16%));
	border-radius: var(--fl-radius-sm, 6px);
	background: var(--fl-white, #fff);
	font: inherit;
	font-family: var(--fl-font-sans);
	font-size: 0.9375rem;
	color: var(--fl-charcoal, #171717);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.fl-learner-access__field input::placeholder {
	color: rgb(138 132 124 / 72%);
}

.fl-learner-access__field input:focus {
	outline: none;
	border-color: var(--fl-gold, #b98a3d);
	box-shadow: 0 0 0 3px rgb(185 138 61 / 14%);
}

.fl-learner-access__field--checkbox label {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: normal;
	color: var(--fl-stone, #8a847c);
}

.fl-learner-access__field--checkbox input {
	width: auto;
	margin: 0;
	accent-color: var(--fl-gold, #b98a3d);
}

.fl-learner-access__form .fl-btn {
	width: 100%;
	min-height: 2.875rem;
	margin-top: 0.25rem;
	font-family: var(--fl-font-sans);
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: none;
	border-radius: var(--fl-radius-sm, 6px);
}

.fl-learner-access__links {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.25rem;
	padding-top: 1.25rem;
	border-top: 1px solid var(--fl-border, rgb(23 23 23 / 10%));
}

@media (width >= 480px) {
	.fl-learner-access__links {
		flex-flow: row wrap;
		gap: 1rem 1.5rem;
	}
}

.fl-learner-access__links a {
	color: var(--fl-gold, #b98a3d);
	font-family: var(--fl-font-sans);
	font-size: 0.875rem;
	font-weight: 500;
	text-decoration: none;
}

.fl-learner-access__links a:hover {
	color: var(--fl-charcoal, #171717);
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.fl-learner-access__links a.fl-btn {
	text-decoration: none;
	text-align: center;
}

.fl-learner-access__steps {
	margin: 0 0 1.5rem;
	padding-left: 1.25rem;
	font-family: var(--fl-font-sans);
	color: var(--fl-stone, #8a847c);
	line-height: 1.65;
}

.fl-learner-access .fl-btn--primary {
	background: var(--fl-charcoal, #171717);
	border: 1px solid var(--fl-charcoal, #171717);
	color: var(--fl-ivory, #f7f3ec);
}

.fl-learner-access .fl-btn--primary:hover {
	background: rgb(23 23 23 / 88%);
	border-color: rgb(23 23 23 / 88%);
}

.fl-learner-access .fl-btn--secondary {
	background: transparent;
	border: 1px solid var(--fl-border-strong, rgb(23 23 23 / 16%));
	color: var(--fl-charcoal, #171717);
}
