/* ============================================================
   EAPL Tool Login — login page CSS
   Scoped to .eapl-login. Loaded only on /tools/login/.
   Variables fall through to theme tokens.css with hard fallbacks.
   ============================================================ */

/* Theme override — the eapl theme's .container-longform wrapper
   (used for editorial pages like /the-design-advantage/) adds
   large vertical padding by design. Single-purpose pages like
   sign-in shouldn't inherit that. This rule fires only on
   /tools/login/ because login.css is enqueued only there. */
article.container-longform,
article.page-body.container-longform,
.site-main article.container-longform {
	padding-top: 0 !important;
}

.eapl-login {
	/* Layout geometry — explicit on all four sides; never relies on
	   template padding. */
	padding: clamp(2rem, 4vw, 3.5rem) 2rem clamp(3rem, 6vw, 5rem);
	background: var(--color-bg-primary, #FAF8F5);
	font-family: var(--font-body, 'Inter', -apple-system, system-ui, sans-serif);
	color: var(--color-text-primary, #1A1A1A);
	line-height: 1.6;
}

.eapl-login *,
.eapl-login *::before,
.eapl-login *::after {
	box-sizing: border-box;
}

.eapl-login__col {
	max-width: 880px;
	margin: 0 auto;
}

/* Header */

.eapl-login__kicker {
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--color-text-tertiary, #8A8A85);
	margin: 0 0 1.5rem 0;
}

.eapl-login__title {
	font-family: var(--font-display, 'Source Serif 4', Georgia, serif);
	font-size: clamp(2.25rem, 4.5vw, 3.5rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--color-text-primary, #1A1A1A);
	margin: 0 0 2rem 0;
}

.eapl-login__rule {
	width: 56px;
	height: 2px;
	background: var(--color-accent, #E8740C);
	margin: 0;
	border: none;
}

/* Form region — narrower than the editorial column for focus. */

.eapl-login__form-region {
	margin-top: clamp(3rem, 6vw, 5rem);
	max-width: 460px;
}

/* Field */

.eapl-login__field {
	margin: 0 0 1.5rem 0;
}

.eapl-login__field label {
	display: block;
	font-size: 0.75rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-text-secondary, #555555);
	margin: 0 0 0.625rem 0;
}

.eapl-login__field input {
	width: 100%;
	font-family: var(--font-body, 'Inter', -apple-system, system-ui, sans-serif);
	font-size: 1.0625rem;
	line-height: 1.4;
	color: var(--color-text-primary, #1A1A1A);
	background: #FFFFFF;
	border: 1px solid var(--color-rule-strong, #B8AE9C);
	border-radius: 0;
	padding: 0.875rem 1rem;
	transition: border-color 180ms ease, box-shadow 180ms ease;
	-webkit-appearance: none;
	appearance: none;
}

.eapl-login__field input:focus {
	outline: none;
	border-color: var(--color-accent, #E8740C);
	box-shadow: 0 0 0 1px var(--color-accent, #E8740C);
}

.eapl-login__field input::placeholder {
	color: var(--color-text-tertiary, #8A8A85);
	opacity: 1;
}

/* Code input — monospaced, larger, letter-spaced. */

.eapl-login__field input.is-code {
	font-family: var(--font-mono, 'JetBrains Mono', ui-monospace, Menlo, monospace);
	font-size: 1.5rem;
	letter-spacing: 0.18em;
	text-align: left;
	padding-left: 1.125rem;
	font-variant-numeric: tabular-nums;
}

/* Submit */

.eapl-login__submit {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-body, 'Inter', -apple-system, system-ui, sans-serif);
	font-size: 0.9375rem;
	font-weight: 500;
	letter-spacing: 0.04em;
	color: var(--color-bg-primary, #FAF8F5);
	background: var(--color-dark, #2D2D2D);
	border: none;
	border-radius: 0;
	padding: 0.875rem 1.5rem;
	cursor: pointer;
	transition: background 180ms ease;
	-webkit-appearance: none;
	appearance: none;
}

.eapl-login__submit:hover {
	background: #1a1a1a;
}

.eapl-login__submit:focus {
	outline: 2px solid var(--color-accent, #E8740C);
	outline-offset: 2px;
}

.eapl-login__submit .arrow {
	font-family: var(--font-display, 'Source Serif 4', Georgia, serif);
	font-size: 1rem;
	line-height: 1;
}

/* Error strip */

.eapl-login__error {
	font-size: 0.875rem;
	line-height: 1.55;
	padding: 0.75rem 1rem;
	margin: 0 0 1.5rem 0;
	color: #8A2A0E;
	background: #FBEEE6;
	border-left: 2px solid #C44918;
}

/* Access note (always visible, below form) */

.eapl-login__note {
	margin-top: clamp(3rem, 5vw, 4.5rem);
	padding-top: 2rem;
	border-top: 1px solid var(--color-rule, #D9D2C6);
	font-size: 0.875rem;
	line-height: 1.65;
	color: var(--color-text-secondary, #555555);
	max-width: 56ch;
}

.eapl-login__note a {
	color: var(--color-text-primary, #1A1A1A);
	border-bottom: 1px solid var(--color-accent, #E8740C);
	padding-bottom: 1px;
	text-decoration: none;
}

/* ============================================================
   Responsive
   ============================================================ */

@media (max-width: 720px) {
	.eapl-login {
		padding-left: 1rem;
		padding-right: 1rem;
	}
	.eapl-login__field input.is-code {
		font-size: 1.25rem;
		letter-spacing: 0.14em;
	}
}
